高可用之keepalived&haproxy | 您所在的位置:网站首页 › keepalived haproxy 配置 › 高可用之keepalived&haproxy |
高可用之keepalived&haproxy
2018-02-25
devops
约 10390 字
预计阅读 21 分钟
文章目录
项目中用到了keepalived及haproxy来实现服务的高可用,防止单点故障。以前其实也用过keepalived及nginx实现类似的功能,当时没有作记录,这里作一下记录以备忘。 Keepalived keepalived是什么keepalived是集群管理中保证集群高可用的一个服务软件,其功能类似于heartbeat,用来防止单点故障。 keepalived工作原理keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。 虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。 keepalived主要有三个模块,分别是core、check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。 keepalived的配置文件keepalived只有一个配置文件keepalived.conf,里面主要包括以下几个配置区域,分别是global_defs、static_ipaddress、static_routes、vrrp_script、vrrp_instance和virtual_server。 global_defs区域主要是配置故障发生时的通知对象以及机器标识 global_defs { notification_email { [email protected] [email protected] ... } notification_email_from [email protected] smtp_server smtp.abc.com smtp_connect_timeout 30 enable_traps router_id host163 } notification_email 故障发生时给谁发邮件通知。 notification_email_from 通知邮件从哪个地址发出。 smpt_server 通知邮件的smtp地址。 smtp_connect_timeout 连接smtp服务器的超时时间。 enable_traps 开启SNMP陷阱(Simple Network Management Protocol)。 router_id 标识本节点的字条串,通常为hostname,但不一定非得是hostname。故障发生时,邮件通知会用到。 static_ipaddress和static_routes区域static_ipaddress和static_routes区域配置的是是本节点的IP和路由信息。如果你的机器上已经配置了IP和路由,那么这两个区域可以不用配置。其实,一般情况下你的机器都会有IP地址和路由信息的,因此没必要再在这两个区域配置。 static_ipaddress { 10.210.214.163/24 brd 10.210.214.255 dev eth0 ... } static_routes { 10.0.0.0/8 via 10.210.214.1 dev eth0 ... }以上分别表示启动/关闭keepalived时在本机执行的如下命令: # /sbin/ip addr add 10.210.214.163/24 brd 10.210.214.255 dev eth0 # /sbin/ip route add 10.0.0.0/8 via 10.210.214.1 dev eth0 # /sbin/ip addr del 10.210.214.163/24 brd 10.210.214.255 dev eth0 # /sbin/ip route del 10.0.0.0/8 via 10.210.214.1 dev eth0注意: 请忽略这两个区域,因为我坚信你的机器肯定已经配置了IP和路由。 vrrp_script区域用来做健康检查的,当时检查失败时会将vrrp_instance的priority减少相应的值。 vrrp_script chk_http_port { script " |
CopyRight 2018-2019 实验室设备网 版权所有 |